

## ECSE 222 Digital Logic Lab #1

Alex Gruenwald, 260783506

Kaustav Das Sharma, 260772982

Group #50

A description of the 7-segment decoder circuit. Explain why you used the selected signal assignment instead of the conditional signal assignment?

The 7\_segment\_decoder is the VHDL code in our lab which defines how the displays on the Altera DE1-SoC board will display the values between 0-9 and A-F. Given the initial entity code, all that was required was to code a switch statement (different name in VHDL), going through each possible combination of 4 bits ranging from 0-9 and A-F. When a specific value in this range was given, it corresponded to the 7-bit representation of how it would be displayed on the Altera board. For example, if we wanted to represent a  $7_{10}$  in bits, it would be written  $0111_2$ . With this being the input for the case, the output would be 7 bits corresponding to the bit locations in Figure 1. If we want to create a '7' in the display, the bits corresponding to position 0, 1, and 2 must be one. Because we are basing our display on an active low (active when 0) these 3 bits must be '0' to actually display the right quadrant. The output for this example would be a 7-bit result => '1111000' where the least significant bit represents bit 0 and the most significant bit represents bit 6 in Figure 1.



Figure 1: Bit values and corresponding orientation on the display

When coding the case statement, there were two ways to implement the signal assignments – conditional or selected. Both of these assignments result in the same output but are implemented differently in code. A comparison of the two different types of implementation are shown below in Figure 2 and Figure 3 (random examples not related to actual decoder code). From observation, we can immediately see the difference between the two assignments where the selected signal assignment uses a switch case (similar to one in Java) and the conditional one uses an if / else statement. Implementing the conditional signal assignment implies that every statement must be checked in order to find a statement that matches for each loop. This is incredibly inefficient for the VHDL 7\_segment\_decoder code shown in Figure 4, because there are 16 cases When considering the selected signal

assignment, the switch cases allow for each input to find the right statement almost immediately, ensuring a quick and efficient implementation of the code.

```
g50_r_segment_decoder.vhd g50_adder.vhd g50_
```

Figure 2: VDHL code representing how selected signal assignment is written

Figure 3: VDHL code representing how conditional signal assignment is written

To summarize our decision for using selected signal assignments, we did it for implementation efficiency. When considering large amounts of input bits, using the conditional assignment will result in a large waiting time for each if/else statement to be found. Using a selected signal assignment ensures a quick comparison and output for each loop.

## A discussion of how the 7-segment decoder circuit was tested, showing representative simulation plots. How do you know that the circuit works correctly?

To test the 7-segment decoder circuit, we compiled the VDHL file on ModelSim and extracted the signals into the wave-viewer to run and visualise the output. The results of this simulation are shown **Figure 4 & 5**, and it shows that each of the corresponding outputs are decoded correctly. For example, the "0" represents the output on the display of the Altera and below it are the bits that need to be activated in order to produce it. These bits are "active-low" which implies that 0 represents the respective quadrant being "on".



Figure 4: Simulated 7 segment decoder (left-view)



Figure 5: Simulated 7\_segment\_decoder (right-view)

## A description of the adder circuit. How many 7-segment decoder instances did you use in your design and why?

The adder is directly connected to the LED displays on the Altera board. Since the LED displays on the board are grouped in twos, we labelled a grouping with two variables (A0 and A1) and used the size of the std\_logic\_vector to separate each display in the grouping. For example, (13 downto 0) can be separated into one range from (13 downto 7) corresponding to A0 and (6 downto 0) corresponding to A1. With the range separated, all six displays can then be accessed.

When considering the switches, they are separated into two sections, std\_logic\_vector A and B where A represents the first five switches and B represents the second grouping of switches as seen in **Figure 6**.



Figure 6: vectors A and B locations as seen on the switches

Depending on which switch is activated, a binary value, based on the location of the switch in the grouping of 5, will be sent to another vector  $A_pad$  for an A switch or  $B_pad$  for a B switch where the 5 bit binary value will be concatenated with an initial " $000_2$ " to make an 8 bit output, which is then separated into two 4-bit groupings for the displays. The creation of the 4-bit value can then be inputted into the  $7_segment_coder$  and turned into a 7-bit combination which is read as a hexadecimal value on the display. For the 5-bit vector of A or B, initially seen as ' $00000_2$ ', the switch location on the board corresponds to the location of the binary value that will be changed to a 1.

For example, B[2] which is the third switch as seen in **Figure 6**, will change the 3<sup>rd</sup> bit in the 5 bits: '00**1**00<sub>2</sub>'. This is then concatenated with '000<sub>2</sub>' in the B\_pad vector to make '00000100<sub>2</sub>' which is then split into two groups of 4-bits: '0000<sub>2</sub>' and '0100<sub>2</sub>'. Concatenating a '000' allows for an easy split of the now 8-bit value as the 7\_segment\_coder requires at most 4 bits as an input and not 5. Also, the 5<sup>th</sup> bit can now easily be represented on the second display as it composed of 4-bits as well. These values are then inputted into the 7\_segment\_decoder where '0000<sub>2</sub>' (0<sub>10</sub>) will be converted as '1000000<sub>2</sub>' and '0100<sub>2</sub>' (4<sub>10</sub>) will be converted to '0011001<sub>2</sub>'. Now, with the correct binary representation of a hexadecimal number, the 7\_segment\_decoder outputs the 7-bit value into the LED display variables called

decoded\_A, decoded\_B, and decoded\_AplusB as seen on the display in **Figure 6.** For the final step, the decoded\_B and the decoded\_AplusB displays are updated with the input bits where the range from (13 downto 7) will have '10000002' and the (6 downto 0) range will have '00110012' which results in a display of '01' for both the decoded\_B display as well as the decoded AplusB display.

If the A switches were activated with the B switches, the same steps would apply to A, except now the decoded\_AplusB would have an extra step of adding the two binary digits together. In this addition, 6 bits (unsigned) of space are allocated in case the addition goes over the 5-bit limit.

For example,  $'10000_2' + '10000_2' = '100000_2'$  which now represents  $'20_{16}'$ 

To answer the second part of the question, 6 instances of the 7\_segment\_decoder were used in the implementation of the adder code where all 6 instances can be seen in **Figure 6.** The reason for this implementation is because we are adding 5-bit values together. This 5-bit output is an issue for the input into the 7\_segment\_decoder because the 7\_segment\_decoder outputs a 7-bit binary value that <u>represents</u> a hexadecimal value. Hexadecimal values are written in pairings of 4-bits, so a 5-bit input would not result in a single hexadecimal value. To account for this, we concatenate '000<sub>2</sub>' to the end of each A, B, and sum vector resulting in each having a total of 8-bits. This is then split into two 4-bit variables (as seen in **Figure 6**), where each is then turned into a hexadecimal representation for the display. Since there are three groupings of displays, one for A, B and the sum, and each display has two hexadecimal values, there needs to be a total of 6 displays, where each display has an instance of the 7\_segment\_decoder linked to it.

## A discussion of how the adder circuit was tested?

To test the adder circuit, we tested various combinations of switch configurations, however for the purpose of this report, here are three specific test cases. Figure 7 represents the scenario where all the switches are turned on. As explained previously, the first four LED displays are the numbers (in hexadecimal) being summed to get the output in the last two LED displays. Hence for this test case, we have  $(1F_{16} \approx 31_{10}) + (1F_{16} \approx 31_{10}) = (3E_{16} \approx 62_{10})$ . Figure 8 is the scenario where are the switches are turned off, which means it's  $(00_{16} \approx 0_{10}) + (00_{16} \approx 0_{10})$ 

 $0_{10}$ ) =  $(00_{16} \approx 0_{10})$ . Lastly, Figure 9 shows a specific test case triggering  $(01_{16} \approx 1_{10})$  +  $(01_{16} \approx 1_{10})$  =  $(02_{16} \approx 02_{10})$ .



Figure 7: All switches on



Figure 8: All switches off



Figure 9: Basic adder test case

A summary of the FPGA resource utilization (from the Compilation Report's Flow Summary) and the RTL schematic diagram for both the 7-segment decoder and the adder circuits. Clearly specify which part of your code maps to which part of the schematic diagram?

Figure 10 corresponds to the compilation flow report summary outputted from our VHDL code in Altera. Figure 11 and 12 corresponds to resulting RTL schematic diagrams from our code.



Figure 10: Compilation flow summary report



Figure 11: RTL Schematic for decoder circuit

The code[3..0] in the schematic diagram above corresponds to the input which is a 4 bit value, which then goes through a series of multiplexers which transforms the input to the desired 7 segment display representation (segments[6,0]), by turning active low bits into 0s.



Figure 12: RTL Schematic for adder circuit

In the schematic diagram above, the A[4..0] and B[4..0] corresponds to the switches on the hardware, which then has three pathways. The first corresponds to the decoder which parses the input signal and displays the resultant hexadecimal into i3 and i4. The same happens in the bottom pathway, except it displays onto i1 and i2. The middle pathway corresponds to the display which adds A and B, so it goes through the adder and then parses it to a hexadecimal and displays on i5 and i6.